## CLAIMS

A cache memory comprising: [1]

10

15

20

25

30

an addition unit operable to add, to each cache entry holding line data, a caching termination attribute indicating whether or not 5 caching of the cache entry is allowed to be terminated;

a selection unit operable to select a cache entry that has been added with a caching termination attribute indicating that caching is allowed to be terminated, and has been set with a dirty flag indicating that the cache entry has been written into; and

a write back unit operable to write back, to a memory, line data of the selected cache entry, regardless of an occurrence of a cache miss.

The cache memory according to Claim 1, [21 wherein said adding unit includes:

a holding unit operable to hold an address range specified by

a search unit operable to search for a cache entry holding line a processor; data within the address range held in said holding unit; and

a setting unit operable to set, to the searched-out cache entry, the caching termination attribute indicating that caching is allowed to be terminated.

The cache memory according to Claim 2, [3] wherein said search unit includes:

a first conversion unit operable, in the case where a start address of the address range held in said holding unit indicates a point midway through line data, to convert the start address into a start line address indicating a start line included in the address range;

a second conversion unit operable, in the case where an end address of the address range held in said holding unit indicates a point midway through line data, to convert the end address into an end line address indicating an end line included in the address

a judgment unit operable to judge whether or not there exist range; and cache entries holding data corresponding to respective line addresses from the start line address to the end line address.

- The cache memory according to Claim 2, further comprising a replacement unit operable, when a cache miss occurs, to [4] select, as a subject for replacement, the cache entry that has been added with the caching termination attribute indicating that caching 10 is allowed to be terminated.
  - The cache memory according to Claim 1, [5] wherein said addition unit includes:

15

20

30

an instruction detection unit operable to detect execution, by a processor, of a store instruction having, as instruction details, addition of the caching termination attribute indicating that caching is allowed to be terminated, and writing of data; and

a setting unit operable to set the caching termination attribute to a cache entry that has been written into in accordance with the detected instruction.

- The cache memory according to Claim 1, wherein said write back unit is operable to write back data of 161 a cache entry to the memory, when a memory bus has an idle cycle. 25
  - The cache memory according to Claim 1, wherein each cache entry has a dirty flag for each of a [7] plurality of sub-lines making up one line, and said write back unit is operable to write back, to the memory,

only a dirty sub-line of the cache entry selected by said selection

unit.

[8] A control method for use in a cache memory, comprising:

an addition step of adding, to each cache entry holding line data, a caching termination attribute indicating whether or not caching of the cache entry is allowed to be terminated;

a selection step of selecting a cache entry that has been added with a caching termination attribute indicating that caching is allowed to be terminated, and has been set with a dirty flag indicating that the cache entry has been written into; and

a write back step of writing back, to a memory, line data of the selected cache entry, regardless of an occurrence of a cache miss.

15

10

5

20